easy-parallel
Run closures in parallel.
This is a simple primitive for spawning threads in bulk and waiting for them to complete. Threads are allowed to borrow local variables from the main thread.
Examples
Run two threads that increment a number:
use Parallel;
use Mutex;
let mut m = new;
new
.add
.add
.run;
assert_eq!;
Square each number of a vector on a different thread:
use Parallel;
let v = vec!;
let squares = new
.each
.run;
assert_eq!;
Compute the sum of numbers in an array:
use Parallel;
let v = ;
assert_eq!;
License
Licensed under either of
- Apache License, Version 2.0 (LICENSE-APACHE or http://www.apache.org/licenses/LICENSE-2.0)
- MIT license (LICENSE-MIT or http://opensource.org/licenses/MIT)
at your option.
Contribution
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.